-
Notifications
You must be signed in to change notification settings - Fork 4.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
split HINT_THE_LOCATION from PRESERVE_SPAWN_OMT flag #78193
split HINT_THE_LOCATION from PRESERVE_SPAWN_OMT flag #78193
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm being direct in the review. This is not intended to be offensive, so I hope it's not taken that way.
6987f92
to
920e35d
Compare
920e35d
to
fa42619
Compare
My understanding of your description is that some EOC was using an undefined variable (because the phone lacked the original flag), so it generated this variable with and puts the current PC location in some random coordinate format into it? That sounds like a horrible fallback. Rather than flagging a problem it's hidden away and some random problem occurs down the line. If it is intended that phones should store a location it should presumably mean the EOC won't generate the variable with random crap, but rather read the variable generated at item creation. However, the "fallback" of hiding the problem on an EOC failure should be removed: if the variable doesn't exist the EOC should fail with an error message saying an expected variable of name so-and-so doesn't exist. If possible, the EOC should fail gracefully rather than crash the program. |
That is correct, that is horrible, and it was not even intentional, i checked some code, but didn't found at which moment it happens exactly. You can check for yourself, the json https://github.com/CleverRaven/Cataclysm-DDA/blob/master/data/json/effects_on_condition/computer_eocs.json#L49 do not contain any fallbacks, and checking some related eoc functions i was not able to detect anything suspicious either There is a longstanding issue of eoc having lack of variable declaration, therefore all read variables that do not exist are created ad-hoc with assumed value of zero, so i suspect this coordinate issue is part of it - Andrei talked that they would like it to be different, but it would require to redo a giant amount of code and json |
Good to hear we are in agreement. The EOC you reference applies the location_variable_adjust effect to spawn_location_omt without verifying that variable exists, which it probably should. The code (npc_talk.cpp operation f_location_variable_adjust around line 4255 performs the requested manipulation on what's extracted from input_var via get_tripoint_from_var. get_tripoint_from_var is called with input_var as a parameter and is_npc= false. It then extracts and returns a tripoint_abs_ms from the input_var if it has a value. If it doesn't it generates a debug message and tripoint_abs_ms::invalid, but only if This possibly correct, possibly invalid, and possibly PC abs_ms position is then modified as directed and written back into output_var if existing, or input_var if not. In my opinion, get_tripoint_from_var should generate an error message rather than a debug message, and should do so regardless of whether is_npc is true or not. It should also return invalid regardless, and f_location_variable_adjust should check the result of the value returned, and only perform the operation if the value isn't It can be noted that the manipulation works when the variable exists despite the incorrect coordinates used, because they're written back the same way as they were read, but it's not pretty (and completely wrong when "defaulted" to a position in a different coordinate system). Note that if the var contains |
I'm assuming this needs some followup reviews before merge based on what I read above? |
No, not really, discussion above speaks about general issues in eoc coordinates, that need much bigger refactoring to be fixed. This one, while uses coordinates, tries to fix pretty different issue |
#78140 was merged, can you retest your changes as you planned? |
Yep, compiled, tested, it doesn't work as i would like (PRESERVE_SPAWN_OMT work only when you spawn items on map, and doesn't work when item is spawned), but it does resolve #78191 |
So do you want this merged or not? |
Yes, it's ready to merge |
Summary
None
Purpose of change
Fix #78191
Describe the solution
Make HINT_THE_LOCATION flag, that duplicate funcitonality of PRESERVE_SPAWN_OMT flag, but is required to hint the location where the item was picked up originally
Testing
It works, but fucks up the map feature for smartphones as per #78191 (comment)see commentAdditional context
Waiting #78140 to be merged to test it once again, in hope it would resolve the problem